36 #include "sensor_io_i2c.h" 37 #include "mpl3115_drv.h" 39 #define MPL3115_MPERCOUNT 0.0000152587890625F // Convert 32-bit Altitude value to meters 40 #define MPL3115_CPERCOUNT 0.00390625F // Convert 16-bit Temperature value to Celcius 41 #define MPL3115_ACCEL_FIFO_SIZE 32 43 #if F_USING_PRESSURE // driver is only pulled in if the appropriate flag is set in build.h 46 const registerreadlist_t MPL3115_WHO_AM_I_READ[] =
48 { .readFrom = MPL3115_WHO_AM_I, .numBytes = 1 }, __END_READ_DATA__
52 const registerreadlist_t MPL3115_F_STATUS_READ[] =
54 { .readFrom = MPL3115_STATUS, .numBytes = 1 }, __END_READ_DATA__
58 registerreadlist_t MPL3115_DATA_READ[] =
60 { .readFrom = MPL3115_OUT_P_MSB, .numBytes = 5 }, __END_READ_DATA__
64 const registerwritelist_t MPL3115_Initialization[] =
73 { MPL3115_CTRL_REG1, 0x00, 0x00 },
82 { MPL3115_CTRL_REG1, 0xB9, 0x00 },
93 status = Register_I2C_Read(sensor->
bus_driver, sensor->
addr, MPL3115_WHO_AM_I, 1, ®);
94 if (status==SENSOR_ERROR_NONE) {
95 sfg->Pressure.iWhoAmI = reg;
96 if (reg!=MPL3115_WHOAMI_VALUE) {
98 return(SENSOR_ERROR_INIT);
107 status = Sensor_I2C_Write(sensor->
bus_driver, sensor->
addr, MPL3115_Initialization );
114 sfg->Pressure.isEnabled =
true;
126 return SENSOR_ERROR_INIT;
129 status = Sensor_I2C_Read(sensor->
bus_driver, sensor->
addr, MPL3115_DATA_READ, I2C_Buffer );
131 if (status==SENSOR_ERROR_NONE) {
133 sfg->Pressure.iH = (I2C_Buffer[0] << 24) | (I2C_Buffer[1] << 16) | (I2C_Buffer[2] << 8);
134 sfg->Pressure.iT = (I2C_Buffer[3] << 8) | I2C_Buffer[4];
137 sfg->Pressure.fH = (float) sfg->Pressure.iH * sfg->Pressure.fmPerCount;
138 sfg->Pressure.fT = (
float) sfg->Pressure.iT * sfg->Pressure.fCPerCount;
140 sfg->Pressure.fH = 0.0;
141 sfg->Pressure.fT = 0.0;
149 const registerwritelist_t MPL3115_IDLE[] =
152 { MPL3115_CTRL_REG1, 0x00, 0x01 },
161 status = Sensor_I2C_Write(sensor->
bus_driver, sensor->
addr, MPL3115_IDLE );
163 sfg->Pressure.isEnabled =
false;
165 return SENSOR_ERROR_INIT;
int8_t MPL3115_Idle(PhysicalSensor *sensor, SensorFusionGlobals *sfg)
#define MPL3115_MPERCOUNT
#define F_USING_PRESSURE
nominally 0x0008 if altimeter is to be used, 0x0000 otherwise
The top level fusion structure.
void * bus_driver
should be of type (ARM_DRIVER_I2C* for I2C-based sensors, ARM_DRIVER_SPI* for SPI) ...
int8_t MPL3115_Init(PhysicalSensor *sensor, SensorFusionGlobals *sfg)
The sensor_fusion.h file implements the top level programming interface.
int8_t MPL3115_Read(PhysicalSensor *sensor, SensorFusionGlobals *sfg)
Provides function prototypes for driver level interfaces.
#define F_USING_TEMPERATURE
nominally 0x0010 if temp sensor is to be used, 0x0000 otherwise
#define MPL3115_CPERCOUNT
An instance of PhysicalSensor structure type should be allocated for each physical sensors (combo dev...
uint16_t isInitialized
Bitfields to indicate sensor is active (use SensorBitFields from build.h)
SensorFusionGlobals sfg
This is the primary sensor fusion data structure.
uint16_t addr
I2C address if applicable.
#define MPL3115_ACCEL_FIFO_SIZE